﻿#define _CRT_SECURE_NO_WARNINGS 1

class Solution {
public:
    int myAtoi(string s)
    {
        int answer = 0;
        int i = 0;
        int flag = 1;
        while (s[i] == ' ')
        {
            ++i;
        }
        if (s[i] == '-')
            flag = -1;
        if (s[i] == '+' || s[i] == '-')
            ++i;
        while (i < s.size() && isdigit(s[i]))//注意第三条要求，读入下一个字符，直到到达下一个非数字字符或到达输入的结尾
        {
            if (answer > (INT_MAX - (s[i] - '0')) / 10)//answer * 10 + (s[i] - '0') < INT_MAX，注意，负号已经被提取了，所以不用关心INT_MIN
            {
                answer = flag == -1 ? INT_MIN : INT_MAX;
                return answer;
            }
            answer = answer * 10 + (s[i] - '0');
            ++i;
        }
        return answer * flag;
    }
};

/*
请你来实现一个 myAtoi(string s) 函数，使其能将字符串转换成一个 32 位有符号整数（类似 C/C++ 中的 atoi 函数）。

函数 myAtoi(string s) 的算法如下：

读入字符串并丢弃无用的前导空格
检查下一个字符（假设还未到字符末尾）为正还是负号，读取该字符（如果有）。 确定最终结果是负数还是正数。 如果两者都不存在，则假定结果为正。
读入下一个字符，直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
将前面步骤读入的这些数字转换为整数（即，"123" -> 123， "0032" -> 32）。如果没有读入数字，则整数为 0 。必要时更改符号（从步骤 2 开始）。
如果整数数超过 32 位有符号整数范围 [−231,  231 − 1] ，需要截断这个整数，使其保持在这个范围内。具体来说，小于 −231 的整数应该被固定为 −231 ，大于 231 − 1 的整数应该被固定为 231 − 1 。
返回整数作为最终结果。
注意：

本题中的空白字符只包括空格字符 ' ' 。
除前导空格或数字后的其余字符串外，请勿忽略 任何其他字符。
*/

